草庐IT

dictionary - 将 map[string]string 转换为 map[someStruct]string

全部标签

function - 将变量 []interface{} 转换为变量 ...interface{} in go

我正在使用gomysql库来执行多个数据库任务。鉴于我想在mysql库上编写一个包装器包,我发现自己陷入了以下情况:我有一个具有以下签名的方法:func(db*MySQL)Insert(querystring,args...interface{})(int64,错误)此方法从具有以下签名的库中调用db.Exec函数:func(db*DB)Exec(querystring,args...interface{})(Result,error)似乎当我调用我的方法时Insert("somequery",1,"test")values...interface{}被翻译成[]interface{}

go - 将 if 语句转换为短语句

我有很多if语句anotherName:="ABC"iflen(dict)>0{if_,ok:=dictA["Name"];ok{iffName,ok:=dataDict["Name"];ok{iffName=="SAM"{iflen(dict)>1{mainDict[anotherName]=dict}}}}}我不想使用那么多if语句。我想使用运算符,但在这种情况下无法在此处使用它们。谁能告诉我。 最佳答案 我能想到的一些选项。不确定您是否更喜欢它,或者它是否适用于您的代码:1)在函数中(在循环中使用break):anotherN

go - 转换 map 类型

我正在尝试编写一个通用函数来获取map的键,如下所示:funcMapKeys(theMapmap[interface{}]interface{})([]interface{},error){iftheMap==nil{returnnil,errors.New("MapKeysargisnil")}varkeys=make([]interface{},len(theMap),len(theMap))i:=0foridx,_:=rangetheMap{keys[i]=idxi++}returnkeys,nil}A)有更好的方法吗?和B)调用此函数时,如何将原始map类型转换为map[int

json - golang 将具有数组列表的 json 转换为 golang 中的结构

我刚开始接触golang,我需要从json字符串中获取数据。{"data":["2016-06-21","2016-06-22","2016-06-25"],"sid":"ab","did":"123"}现在我尝试了一个类似的结构typeIntervalDatastruct{Datajson.RawMessage`json:"data"`Didstring`json:"did"`Sidstring`json:"sid"`}typeIntervalDataList[]string和json解码代码,如r:=IntervalData{}json.Unmarshal([]byte(json)

string - 使用 Go 截断 slice 的每个成员

我刚开始使用Go,在完成我想做的事情时遇到了一些麻烦。在加载一个大文本文件后,其中每一行都以我想要的单词开头,然后是我不关心的单空格和多空格分隔文本。我的第一行代码创建了一个行数组lines:=strings.Split(string(file),"\n")下一步将是截断每一行,我可以使用split语句来做到这一点。我确定我可以用for循环来做到这一点,但我正在尝试学习Go中的一些更有效的操作(与c/c++相比)我希望我能做这样的事情lines:=strings.Split((lines...),"")是否有更好的方法来做到这一点,或者我应该只使用某种类型的for循环?

go - 如何将接口(interface)转换为自定义类型

我正在尝试从json字符串中解析出特定字段,目前我有以下代码片段。packagemainimport("encoding/json""fmt")typePlatformIDstringtypeMapmap[string]interface{}funcStr2Map(strstring)(Map,error){vardictionaryMapbytes:=[]byte(str)err:=json.Unmarshal(bytes,&dictionary)iferr!=nil{fmt.Println(err)}returndictionary,err}funcparsePlatformID(

go - 如何检索嵌套的 map 值

我想扫描AWSDynamoDB表,然后只提取某个值。这是我的代码:packagemainimport("fmt""github.com/aws/aws-sdk-go/aws""github.com/aws/aws-sdk-go/aws/session""github.com/aws/aws-sdk-go/service/dynamodb")funcmain(){svc:=dynamodb.New(session.New(),&aws.Config{Region:aws.String("us-west-2")})params:=&dynamodb.ScanInput{TableName:

go - 不能在赋值中使用 &dashUrl(类型 *[]byte)作为类型 *string

我正在尝试解析一个可能为空的表单帖子,如果是,我将更改变量。尝试使用*string类型。我遇到的问题是它不会为dashUrl转换,但会为start_time转换packagemainimport("encoding/base64""strconv""github.com/gocraft/web")typeYoutubeContextstruct{StartTime*float64`json:"start_time"`DashUrl*string`json:"dash_url"`}func(c*YoutubeContext)SetYoutubeContext(rwweb.Response

json - XML 到 json 转换

我有以下XML:2016-09-14T13:58:30Z1.2我将它解码为以下结构:typeValuestruct{Data[]Data`xml:"anyType"`}typeDatastruct{Keystring`xml:"http://www.w3.org/2001/XMLSchema-instancetype,attr"`Valuestring`xml:",chardata"`}我最终想将它们编码为这种结构的json:{timestamp:[thevalueofxsi:type="xsd:dateTime"]value:[thevalueofxsi:type="xsd:deci

MongoDB,戈朗。我可以在不将数据加载到内存的情况下对 slice/ map 进行计数吗?

在我的收藏实验室中,我有:{"_id":ObjectId("57e602ada35ea4db6e4eee27"),"areas":["nanotech","robotics"]}我的查询是:db.labs.find({"_id":ObjectId("57e602ada35ea4db6e4eee27")},{areas:1})我想要的是对slice中的元素进行计数而不是检索整个slice,有人知道吗?我使用的是mgo包,它与golang有很好的对应关系。谢谢 最佳答案 db.labs.aggregate([{$match:{"_id"